home *** CD-ROM | disk | FTP | other *** search
/ Amiga Format CD 43 / Amiga Format CD43 (1999)(Future Publishing)(GB)(Track 1 of 2)[!][issue 1999-09].iso / -serious- / programming / other / gtdrag / examples / dragtest.c < prev    next >
C/C++ Source or Header  |  1999-06-14  |  12KB  |  399 lines

  1. ;/* dragtest.c - Test for the gtdrag.library, 10.6.1999
  2. ;**
  3. ;** Copyright ©1999 pinc Software.
  4. ;** All rights reserved.
  5. ;**
  6. sc dragtest.c link ign=73 lib:debug.lib data=near parm=b nochkabort nostkchk strmer streq to=ram:dragtest
  7. run ram:dragtest
  8. quit
  9. */
  10.  
  11.  
  12. /* This example demonstrates the drag&drop extension of simple
  13. ** Gadtools gadgets and how the DropMessage is analysed.
  14. **
  15. ** It's a very simple example but you may use this code to produce
  16. ** one at your own.
  17. **
  18. ** Although I tried hardly to not produce any errors, I cannot give
  19. ** any guaranties. Neither I nor pinc Software is liable for any
  20. ** problems you might have with it.
  21. ** The usage of this example is on your own risk.
  22. */
  23.  
  24.  
  25. #define INTUI_V36_NAMES_ONLY
  26. #define __USE_SYSBASE
  27.  
  28. #include <exec/libraries.h>
  29. #include <exec/nodes.h>
  30. #include <exec/lists.h>
  31. #include <exec/ports.h>
  32. #include <exec/memory.h>
  33. #include <intuition/intuition.h>
  34. #include <intuition/gadgetclass.h>
  35. #include <graphics/gfx.h>
  36. #include <graphics/gfxmacros.h>
  37. #include <libraries/gadtools.h>
  38. #include <libraries/gtdrag.h>
  39. #include <libraries/asl.h>
  40. #include <dos/dos.h>
  41.  
  42. #include <clib/alib_protos.h>
  43. #include <clib/alib_stdio_protos.h>
  44. #include <clib/gtdrag_protos.h>
  45. #include <proto/exec.h>
  46. #include <proto/gadtools.h>
  47. #include <proto/intuition.h>
  48. #include <proto/graphics.h>
  49. #include <proto/layers.h>
  50. #include <proto/utility.h>
  51. #include <proto/dos.h>
  52. #include <pragmas/gtdrag_pragmas.h>
  53.  
  54. #include <stdlib.h>
  55. #include <ctype.h>
  56. #include <string.h>
  57.  
  58. void main(int, char **);
  59.  
  60. #define TLn(t) TextLength(&scr->RastPort,t,strlen(t))
  61.  
  62.  
  63. UWORD chip newImgData[52] =
  64. {
  65.         /* Plane 0 */
  66.         0x0000,0x0020,0x3FFF,0xFFE0,0x3FFF,0xFFE0,0x3FFF,0xFFE0,
  67.         0x3FFF,0xFFE0,0x3FFF,0xFFE0,0x3FFF,0xFFE0,0x3FFF,0xFFE0,
  68.         0x3FFF,0xFFE0,0x3FFF,0xFFE0,0x3FFF,0xFFE0,0x3FFF,0xFFE0,
  69.         0x7FFF,0xFFE0,
  70.         /* Plane 1 */
  71.         0xFFFF,0xFFC0,0xFFFF,0xFF80,0xF3BF,0xFF80,0xF3BF,0xFF80,
  72.         0xF5B3,0x6D80,0xF5AD,0x6D80,0xF6A1,0xAB80,0xF6AF,0xAB80,
  73.         0xF72D,0xD780,0xF733,0xD780,0xFFFF,0xFF80,0xFFFF,0xFF80,
  74.         0x8000,0x0000
  75. };
  76.  
  77. struct Image newImg = {0,0,27,13,2,newImgData,0x0003,0x0000,NULL};
  78.  
  79. struct Screen *scr;
  80. struct Window *win;
  81. struct IntuiMessage imsg;
  82. struct Library *GTDragBase;
  83. struct Gadget *glist,*lvgad[2],*gad[3];
  84. struct NewGadget ng;
  85. struct List list[2];
  86. struct Node *node;
  87. struct ImageNode in;
  88. APTR   vi;
  89. int    fontheight;
  90. BOOL   ende = FALSE;
  91.  
  92.  
  93. /**************** Requester ****************/
  94.  
  95. long DoRequestA(STRPTR t,STRPTR gads,APTR args)
  96. {
  97.   struct EasyStruct es = {sizeof(struct EasyStruct),0,"DragTest-Request",NULL,NULL};
  98.  
  99.   es.es_TextFormat = t;
  100.   es.es_GadgetFormat = gads;
  101.   return(EasyRequestArgs(scr->FirstWindow,&es,0,args));
  102. }
  103.  
  104.  
  105. void ErrorRequest(STRPTR t,...)
  106. {
  107.   DoRequestA(t,"Ok",&t+1);
  108. }
  109.  
  110.  
  111. /**************** list manipulation ****************/
  112.  
  113. void InsertAt(struct List *l,struct Node *n,int pos)
  114. {
  115.   struct Node *pn;
  116.   int    i;
  117.  
  118.   for(pn = (struct Node *)l,i = 0;i < pos;pn = pn->ln_Succ,i++);
  119.   Insert(l,n,pn);
  120. }
  121.  
  122.  
  123. void MoveTo(struct Node *n,struct List *l1,int pos1,struct List *l2,int pos2)
  124. {
  125.   struct Node *pn;
  126.   int    i;
  127.  
  128.   if (l1 == l2 && pos1 == pos2)
  129.     return;
  130.   Remove(n);
  131.  
  132.   if (l1 == l2 && pos1 < pos2)
  133.     pos2--;
  134.   for(pn = (struct Node *)l2,i = 0;i < pos2 && pn->ln_Succ;pn = pn->ln_Succ,i++);
  135.   Insert(l2,n,pn);
  136. }
  137.  
  138.  
  139. /**************** main part ****************/
  140.  
  141. void processMsg(void)
  142. {
  143.   struct IntuiMessage *msg;
  144.   struct DropMessage *dm;
  145.   int    source,target;
  146.  
  147.   while(!ende)
  148.   {
  149.     WaitPort(win->UserPort);
  150.     while(msg = GTD_GetIMsg(win->UserPort))
  151.     {
  152.       imsg = *msg;
  153.  
  154.       if (imsg.Class == IDCMP_OBJECTDROP)
  155.       {
  156.         if (dm = imsg.IAddress)
  157.         {
  158.           if (!dm->dm_Object.od_Owner && dm->dm_Target)
  159.           {
  160.             target = dm->dm_Target->GadgetID;
  161.             switch(target)
  162.             {
  163.               case 1:
  164.               case 2:
  165.                 source = dm->dm_Gadget->GadgetID;
  166.                 if (source < 3)
  167.                 {
  168.                   source--;  target--;
  169.                   GT_SetGadgetAttrs(lvgad[0],win,NULL,GTLV_Labels,~0L,TAG_END);
  170.                   GT_SetGadgetAttrs(lvgad[1],win,NULL,GTLV_Labels,~0L,TAG_END);
  171.                   if (target)
  172.                     MoveTo(dm->dm_Object.od_Object,&list[source],dm->dm_SourceEntry,&list[target],dm->dm_TargetEntry);
  173.                   else
  174.                   {
  175.                     Remove(dm->dm_Object.od_Object);
  176.                     AddTail(&list[target],dm->dm_Object.od_Object);
  177.                   }
  178.                   GT_SetGadgetAttrs(lvgad[0],win,NULL,GTLV_Labels,&list[0],TAG_END);
  179.                   GT_SetGadgetAttrs(lvgad[1],win,NULL,GTLV_Labels,&list[1],TAG_END);
  180.                 }
  181.                 else
  182.                 {
  183.                   target--;
  184.                   GT_SetGadgetAttrs(lvgad[target],win,NULL,GTLV_Labels,~0L,TAG_END);
  185.                   if (node = AllocMem(sizeof(struct Node),MEMF_CLEAR | MEMF_PUBLIC))
  186.                   {
  187.                     node->ln_Name = in.in_Name;
  188.                     InsertAt(&list[target],node,dm->dm_TargetEntry);
  189.                   }
  190.                   GT_SetGadgetAttrs(lvgad[target],win,NULL,GTLV_Labels,&list[target],TAG_END);
  191.                 }
  192.                 break;
  193.               case 3:
  194.                 DisplayBeep(NULL);
  195.                 break;
  196.               case 4:
  197.               case 5:
  198.                 source = dm->dm_Gadget->GadgetID-1;
  199.                 GT_SetGadgetAttrs(lvgad[source],win,NULL,GTLV_Labels,~0L,TAG_END);
  200.                 if (target == 4)
  201.                 {
  202.                   if (node = AllocMem(sizeof(struct Node),MEMF_CLEAR | MEMF_PUBLIC))
  203.                   {
  204.                     node->ln_Name = ((struct ImageNode *)dm->dm_Object.od_Object)->in_Name;
  205.                     AddTail(&list[source],node);
  206.                   }
  207.                 }
  208.                 else
  209.                 {
  210.                   Remove((struct Node *)dm->dm_Object.od_Object);
  211.                   FreeMem(dm->dm_Object.od_Object,sizeof(struct Node));
  212.                 }
  213.                 GT_SetGadgetAttrs(lvgad[source],win,NULL,GTLV_Labels,&list[source],TAG_END);
  214.                 break;
  215.             }
  216.           }
  217.           else if (!dm->dm_Object.od_Owner)
  218.           {
  219.             DisplayBeep(NULL);   // unsupported drag?!
  220.           }
  221.           else if (!stricmp(dm->dm_Object.od_Owner,"dragtest"))
  222.           {
  223.             char t[256];
  224.  
  225.             if (GTD_GetString(&dm->dm_Object,t,256))
  226.               ErrorRequest("I do not want a node from a clone of mine.\nEspecially, I don't like \"%s\".",t);
  227.           }
  228.           else
  229.             ErrorRequest("An object from %s?\nSounds interesting.",dm->dm_Object.od_Owner);
  230.         }
  231.         else
  232.           DisplayBeep(NULL);
  233.       }
  234.       GTD_ReplyIMsg(msg);
  235.  
  236.       switch(imsg.Class)
  237.       {
  238.         case IDCMP_GADGETDOWN:
  239.           break;
  240.         case IDCMP_GADGETUP:
  241.           switch(((struct Gadget *)imsg.IAddress)->GadgetID)
  242.           {
  243.             case 3:
  244.               GT_SetGadgetAttrs(lvgad[0],win,NULL,GTLV_Labels,~0L,TAG_END);
  245.               if (node = AllocMem(sizeof(struct Node),MEMF_CLEAR | MEMF_PUBLIC))
  246.               {
  247.                 node->ln_Name = in.in_Name;
  248.                 AddTail(&list[0],node);
  249.               }
  250.               GT_SetGadgetAttrs(lvgad[0],win,NULL,GTLV_Labels,&list[0],TAG_END);
  251.               break;
  252.           }
  253.           break;
  254.         case IDCMP_CLOSEWINDOW:
  255.           ende = TRUE;
  256.           break;
  257.       }
  258.     }
  259.   }
  260. }
  261.  
  262. const STRPTR txt[] = {"1","2","3","4","5","6","7","8","9","10","11","12","13","14","15","16","17","18","19","20"};
  263.  
  264. struct Window *initWindow(void)
  265. {
  266.   struct Window *win;
  267.  
  268.   gad[0] = CreateContext(&glist);
  269.  
  270.   ng.ng_LeftEdge = 8;
  271.   ng.ng_TopEdge = fontheight+7;
  272.   ng.ng_Width = 192;
  273.   ng.ng_Height = 11*fontheight+4;
  274.   ng.ng_VisualInfo = vi;
  275.   ng.ng_TextAttr = scr->Font;
  276.   ng.ng_GadgetText = NULL;
  277.   ng.ng_UserData = NULL;
  278.   ng.ng_GadgetID = 1;
  279.   lvgad[0] = CreateGadget(LISTVIEW_KIND,gad[0],&ng,GTLV_Labels,&list[0],TAG_END);
  280.  
  281.   ng.ng_LeftEdge = 206;
  282.   ng.ng_Width = 186;
  283.   ng.ng_GadgetText = NULL;
  284.   ng.ng_GadgetID++;
  285.   lvgad[1] = CreateGadget(LISTVIEW_KIND,lvgad[0],&ng,GTLV_Labels,&list[1],TAG_END);
  286.  
  287.   ng.ng_TopEdge += ng.ng_Height+3;
  288.   ng.ng_LeftEdge = 8;
  289.   ng.ng_Height = fontheight+4;
  290.   ng.ng_Width = TLn("New")+16;
  291.   ng.ng_Flags = PLACETEXT_IN;
  292.   ng.ng_GadgetText = "New";
  293.   ng.ng_GadgetID++;
  294.   gad[0] = CreateGadget(BUTTON_KIND,lvgad[1],&ng,GA_Immediate,TRUE,TAG_END);
  295.  
  296.   ng.ng_LeftEdge += ng.ng_Width+6;
  297.   ng.ng_Width = TLn("Copy")+16;
  298.   ng.ng_GadgetText = "Copy";
  299.   ng.ng_GadgetID++;
  300.   gad[1] = CreateGadget(BUTTON_KIND,gad[0],&ng,TAG_END);
  301.  
  302.   ng.ng_LeftEdge += ng.ng_Width+6;
  303.   ng.ng_Width = TLn("Delete")+16;
  304.   ng.ng_GadgetText = "Delete";
  305.   ng.ng_GadgetID++;
  306.   gad[2] = CreateGadget(BUTTON_KIND,gad[1],&ng,TAG_END);
  307.  
  308.   if (win = OpenWindowTags(NULL,WA_Title,   "gtdrag - Test",
  309.                                 WA_Flags,   WFLG_CLOSEGADGET | WFLG_DRAGBAR | WFLG_DEPTHGADGET | WFLG_ACTIVATE,
  310.                                 WA_IDCMP,   IDCMP_CLOSEWINDOW | DRAGIDCMP,
  311.                                 WA_Width,   400,
  312.                                 WA_Height,  fontheight*13+23,
  313.                                 WA_Gadgets, glist,
  314.                                 TAG_END))
  315.   {
  316.     GT_RefreshWindow(win,NULL);
  317.     GTD_AddGadget(LISTVIEW_KIND,lvgad[0],win,GTDA_InternalType, 1,
  318.                                              GTDA_NoPosition,   TRUE,
  319.                                              GTDA_Type,        ODT_NODE,
  320.                                              TAG_END);
  321.     GTD_AddGadget(LISTVIEW_KIND,lvgad[1],win,GTDA_InternalType,1,
  322.                                              GTDA_Same,        TRUE,
  323.                                              GTDA_Type,        ODT_NODE,
  324.                                              TAG_END);
  325.     GTD_AddGadget(BUTTON_KIND,gad[0],win,GTDA_Object,      &in,
  326.                                          GTDA_Image,       in.in_Image,
  327.                                          GTDA_InternalType,2,
  328.                                          GTDA_AcceptTypes, 0,
  329.                                          GTDA_Width,       newImg.Width,
  330.                                          GTDA_Height,      newImg.Height,
  331.                                          TAG_END);
  332.     GTD_AddGadget(BUTTON_KIND,gad[1],win,GTDA_AcceptTypes,1,TAG_END);
  333.     GTD_AddGadget(BUTTON_KIND,gad[2],win,GTDA_AcceptTypes,1,TAG_END);
  334.     GTD_AddWindow(win,TAG_END);
  335.     return(win);
  336.   }
  337.   return(NULL);
  338. }
  339.  
  340.  
  341. void cleanup(void)
  342. {
  343.   int i;
  344.  
  345.   for(i = 0;i < 2;i++)
  346.     while(node = RemHead(&list[i]))
  347.       FreeMem(node,sizeof(struct Node));
  348. }
  349.  
  350.  
  351. void init(void)
  352. {
  353.   int i;
  354.  
  355.   NewList(&list[0]);
  356.   NewList(&list[1]);
  357.  
  358.   for(i = 0;i<20;i++)
  359.   {
  360.     if (node = AllocMem(sizeof(struct Node),MEMF_CLEAR | MEMF_PUBLIC))
  361.     {
  362.       node->ln_Name = txt[i];
  363.       AddTail(&list[0],node);
  364.     }
  365.   }
  366.   in.in_Name = "** New **";
  367.   in.in_Image = &newImg;
  368. }
  369.  
  370.  
  371. void main(int argc, char **argv)
  372. {
  373.   if (GTDragBase = OpenLibrary("gtdrag.library",3))
  374.   {
  375.     if (GTD_AddApp("dragtest",GTDA_NewStyle,TRUE,TAG_END))
  376.     {
  377.       if (scr = LockPubScreen(NULL))
  378.       {
  379.         vi = GetVisualInfo(scr,TAG_END);
  380.         fontheight = scr->Font->ta_YSize;
  381.         init();
  382.  
  383.         if (win = initWindow())
  384.         {
  385.           processMsg();
  386.           CloseWindow(win);
  387.         }
  388.         FreeGadgets(glist);
  389.  
  390.         cleanup();
  391.         FreeVisualInfo(vi);
  392.         UnlockPubScreen(NULL,scr);
  393.       }
  394.       GTD_RemoveApp();
  395.     }
  396.     CloseLibrary(GTDragBase);
  397.   }
  398. }
  399.